草庐IT

Python Django 模板 : Iterate Through List

全部标签

c++ - 如何找到用于声明类的模板参数的数量?

如何检索用于构造某个类的模板参数的数量?为了阐明我在追求什么,假设我有一些类实例,Aa;,我运行以下命令以获取其名称:boost::units::detail::demangle(typeid(decltype(a)).name())假设此调用的输出是someNamespace::A,int,5,Arg2>.我想找到一种可靠地获取参数数量的方法(即4),考虑到参数本身可能具有任意数量的嵌套模板参数级别(我不想计算-即。我想要将Arg1计为单个参数),并且参数可以是类型和值的任意组合。我愿意通过手动字符串摔跤来完成这项工作,但我更喜欢使用boost的紧凑型解决方案。/STL.有什么想法吗

c++ - 打印给定类型名称的模板

出于调试目的,我想打印一个类型的名称,所以我创建了一个函数来实现这个目的(事实上,我从另一个SO答案中借用了它,但我现在找不到),该函数看起来像这样:templatestd::stringTypeName(T){autoname=typeid(T).name();intstatus=0;std::unique_ptrres{abi::__cxa_demangle(name,NULL,NULL,&status),std::free};return((status==0)?res.get():name);}LiveDemo它工作正常:inti=0;floatf=0.f;std::cout但

c++ - 任意顺序的多个标签的模板特化

假设我有一个像这样定义的类event_basetemplateclassevent_base{public:usingdelegate_type=std::function;usingid_type=size_t;protected:std::vector>m_funcs;};和一些像这样定义的空标签结构structmutable_tag{};structcallable_tag{};然后我希望能够基于模板包中给定的标签中的一个(或两个)从该基类派生对于单个标签:templateclassevent;templateclassevent:publicevent_base{};templ

c++ - 在宏中包装模板函数调用,或避免特化 void 返回

我有以下功能,允许我包装OpenGL命令并在出现问题时记录:templatestructChecker{staticResrun(conststd::string&function_name,Func&&func,Args&&...args){Resresult=func(std::forward(args)...);check_and_log_error(function_name);returnresult;}};templatestructChecker{staticvoidrun(conststd::string&function_name,Func&&func,Args&&.

c++ - cldoc 在模板部分特化时崩溃

这个问题被标记为不清楚我在问什么。为清楚起见,我要求一种解决方法,以使该文档生成器针对我的代码库正常工作。(也许将作业分成批处理?cldocs可能吗?也许发出不同的命令行选项?也许我的调用是错误的或被误导的?)我已经针对该项目提交了一个错误,您可以在此处找到有关我的环境的一些其他信息(包括位于此处的完整命令行:http://pastebin.com/JxWf9hRB)。https://github.com/jessevdk/cldoc/issues/73原始问题:我正在调查使用cldocs进行自动文档编制。但是,它在我的代码库上崩溃,并出现以下错误:Traceback(mostrece

c++ - noexcept 和模板可能存在的 g++ 错误

当我将模板与noexcept说明符结合使用时,我收到有关不匹配的noexcept说明的错误。它编译了我用过的各种版本的clang和fails在所有版本的gcc中。structY{voidh();};templatestructX{voidf()noexcept(noexcept(std::declval().h()));};templatevoidX::f()noexcept(noexcept(std::declval().h())){}intmain(){}错误:g++-std=c++1y-O2-Wall-pthreadmain.cpp&&./a.outmain.cpp:15:56:

c++ - 从非成员模板函数访问私有(private)内部类类型

考虑以下代码:#includeusingnamespacestd;classOuter{structInner{intnum;};public:staticInnerGetInner(){returnInner{-101};}};//voidfunc1(Outer::Innerinner){//[1]Doesnotcompileasexpected//coutvoidfunc2(Outer::Innerinner,Dummy=Dummy()){cout(Outer::GetInner());//[3]Howdoesthiscompile?//Outer::Innershouldnotb

c++ - 有没有办法仅在实例化特定类模板(特化)时调用初始化函数?

我正在为各种计算功能设计一个包装器。一些底层后端需要在进行任何其他API调用之前调用一些init函数。我可以使用一些在main之前初始化的静态变量,并将其包装在某个函数中,如here所述这样我就可以捕获初始化期间产生的任何错误。我想知道是否有更好的方法来处理这个问题。请注意,永远不会有类模板的实例,因为一切都是typedef或静态成员。 最佳答案 为了解决初始化API仅为某些特化的问题,并且只初始化一次,我会做这样的事情:#includetemplatestructWrapper{//classwhowillbestatically

c++ - 使用模板是否节省内存

在我看来,模板允许我们编写一个适用于不同数据类型的函数或类。堆栈或链表等容器用于存储数据,但一次只能存储一种类型的数据。为了存储不同类型的数据,我们需要编写同一容器类的不同版本。我们可以通过编写类模板来保存这种重复的代码。我知道它可以节省程序员的编写工作。但我想知道使用模板是否节省内存。 最佳答案 这取决于您编写的模板。首先,如果一个模板在每个数据类型上创建一个实例会浪费内存。简单地说,模板实例化生成的代码会为每个实例占用程序空间。有了这样一个模板,就相当于手写每个实例。另一方面,如果给定数据类型的每个实例的代码始终相同,则模板可以

c++ - 为什么T 'skips'的模板参数推导是数组元素的const,而函数参数是对T的const引用?

让我们考虑一下这些定义:/***fulltypeinformationwithtypeid***/templateclassType{};templatestd::stringtypeStr(){returntypeid(Type).name();}/***functiontemplateforparameterdeduction***/templatevoidfunc(constT&a){std::cout()()指向常量的指针如果执行以下语句:constinti=5,*ip=&i;func(ip);输出是:DeducedtypeforTis:4TypeI**PKi**E所以T实际上